public class Offer_11 {
    /*
    *
    *
把一个数组最开始的若干个元素搬到数组的末尾，我们称之为数组的旋转。输入一个递增排序的数组的一个旋转，输出旋转数组的最小元素。例如，数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的一个旋转，该数组的最小值为1。  
示例 1：
输入：[3,4,5,1,2]
输出：1
示例 2：

输入：[2,2,2,0,1]
输出：0
    * */
    public static int MinArray(int[] numbers) {
       int left = 0,right=numbers.length - 1;
       while(left<right){
            int middle = (left+right)/2;
            if(numbers[middle]>numbers[right]){
                left = ++middle;
            }else if(numbers[middle]<numbers[right]){
                right = middle;
            }else{
                right--;
            }
       }
        return numbers[left];
    }
    public static void main(String[] args) {
        int[] numArrays = {3,4,5,1,2};
        System.out.println(MinArray(numArrays));
    }
}
